﻿<phone:PhoneApplicationPage 
    x:Class="ImplicitDataTemplateTester.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
    xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
    xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
    xmlns:assets="clr-namespace:DeepForest.Phone.Assets.Controls;assembly=DeepForest.Phone.Assets"
    xmlns:local="clr-namespace:ImplicitDataTemplateTester"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d" d:DesignWidth="480" d:DesignHeight="768"
    FontFamily="{StaticResource PhoneFontFamilyNormal}"
    FontSize="{StaticResource PhoneFontSizeNormal}"
    Foreground="{StaticResource PhoneForegroundBrush}"
    SupportedOrientations="Portrait" Orientation="Portrait"
    shell:SystemTray.IsVisible="True">

    <phone:PhoneApplicationPage.DataContext>
        <local:MainViewModel />
    </phone:PhoneApplicationPage.DataContext>

    <phone:PhoneApplicationPage.Resources>
        <DataTemplate x:Key="ImplicitDataTemplateTester.Rectangle">
            <Grid Height="120" Width="120">
                <Rectangle StrokeThickness="4">
                    <Rectangle.Stroke>
                        <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                            <GradientStop Color="White" Offset="0"/>
                            <GradientStop Color="#FFC24400" Offset="0.992"/>
                        </LinearGradientBrush>
                    </Rectangle.Stroke>
                    <Rectangle.Fill>
                        <LinearGradientBrush EndPoint="0.5,1" MappingMode="RelativeToBoundingBox" StartPoint="0.5,0">
                            <GradientStop Color="#FFFFEACA"/>
                            <GradientStop Color="#FFFF6200" Offset="0.989"/>
                        </LinearGradientBrush>
                    </Rectangle.Fill>
                </Rectangle>
                <TextBlock Text="{Binding Name}" HorizontalAlignment="Center" VerticalAlignment="Center" />
            </Grid>
        </DataTemplate>
    </phone:PhoneApplicationPage.Resources>

    <!--LayoutRoot is the root grid where all page content is placed-->
    <Grid x:Name="LayoutRoot" Background="Transparent">
        
        <Grid.Resources>
            <DataTemplate x:Key="ImplicitDataTemplateTester.Triangle">
                <Grid Height="120" Width="120">
                    <Path Data="M2,2 L118,2 L61.083332,115.75 z" Stretch="Fill" StrokeThickness="4" UseLayoutRounding="False" Margin="0,0,0,2.25">
                		<Path.Fill>
                			<LinearGradientBrush EndPoint="0.5,1" MappingMode="RelativeToBoundingBox" StartPoint="0.5,0">
                				<GradientStop Color="#FFFFEACA"/>
                				<GradientStop Color="#FF00FF41" Offset="0.989"/>
                			</LinearGradientBrush>
                		</Path.Fill>
                		<Path.Stroke>
                			<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                				<GradientStop Color="White" Offset="0"/>
                				<GradientStop Color="#FF00C263" Offset="0.992"/>
                			</LinearGradientBrush>
                		</Path.Stroke>
                	</Path>
                	<TextBlock Text="{Binding Name}" HorizontalAlignment="Center" VerticalAlignment="Center" />
                </Grid>
            </DataTemplate>
        </Grid.Resources>
        
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>

        <!--TitlePanel contains the name of the application and page title-->
        <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
            <TextBlock x:Name="ApplicationTitle" Text="Implicit DataTemplate" Style="{StaticResource PhoneTextNormalStyle}"/>
            <TextBlock x:Name="PageTitle" Text="test page" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
        </StackPanel>

        <!--ContentPanel - place additional content here-->
        <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
            <Grid.RowDefinitions>
                <RowDefinition Height="410*" />
                <RowDefinition Height="197*" />
            </Grid.RowDefinitions>
            <Grid.Resources>
                <DataTemplate x:Key="ImplicitDataTemplateTester.Triangle">
                    <Grid Height="120" Width="120">
                        <Path Data="M2,2 L118,2 L61.083332,115.75 z" Stretch="Fill" StrokeThickness="4" UseLayoutRounding="False" Margin="0,0,0,2.25">
                            <Path.Fill>
                                <LinearGradientBrush EndPoint="0.5,1" MappingMode="RelativeToBoundingBox" StartPoint="0.5,0">
                                    <GradientStop Color="#FFFFEACA"/>
                                    <GradientStop Color="#FF00FF41" Offset="0.989"/>
                                </LinearGradientBrush>
                            </Path.Fill>
                            <Path.Stroke>
                                <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                    <GradientStop Color="White" Offset="0"/>
                                    <GradientStop Color="#FF00C263" Offset="0.992"/>
                                </LinearGradientBrush>
                            </Path.Stroke>
                        </Path>
                        <TextBlock Text="{Binding Name}" HorizontalAlignment="Center" VerticalAlignment="Center" />
                    </Grid>
                </DataTemplate>
            </Grid.Resources>

            <ContentControl VerticalAlignment="Center"
                            HorizontalAlignment="Center"
                            Content="{Binding SelectedShape, Mode=OneWay}">
                
                <i:Interaction.Behaviors>
                    <assets:ImplicitContentTemplateBehavior />
                </i:Interaction.Behaviors>
                
            </ContentControl>
            
            <ListBox Grid.Row="1"
                     VerticalAlignment="Center"
                     HorizontalAlignment="Center"
                     ItemsSource="{Binding Shapes}"
                     SelectedItem="{Binding SelectedShape, Mode=TwoWay}">

                <i:Interaction.Behaviors>
                    <assets:ImplicitItemTemplateBehavior/>
                </i:Interaction.Behaviors>

                <ListBox.ItemContainerStyle>
                    <Style TargetType="ListBoxItem">
                        <Setter Property="Margin" Value="8" />
                    </Style>                          
                </ListBox.ItemContainerStyle>
                <ListBox.ItemsPanel>
                    <ItemsPanelTemplate>
                        <StackPanel Orientation="Horizontal" />
                    </ItemsPanelTemplate>
                </ListBox.ItemsPanel>                
            </ListBox>            

        </Grid>
    </Grid>
 
    <!--Sample code showing usage of ApplicationBar-->
    <!--<phone:PhoneApplicationPage.ApplicationBar>
        <shell:ApplicationBar IsVisible="True" IsMenuEnabled="True">
            <shell:ApplicationBarIconButton IconUri="/Images/appbar_button1.png" Text="Button 1"/>
            <shell:ApplicationBarIconButton IconUri="/Images/appbar_button2.png" Text="Button 2"/>
            <shell:ApplicationBar.MenuItems>
                <shell:ApplicationBarMenuItem Text="MenuItem 1"/>
                <shell:ApplicationBarMenuItem Text="MenuItem 2"/>
            </shell:ApplicationBar.MenuItems>
        </shell:ApplicationBar>
    </phone:PhoneApplicationPage.ApplicationBar>-->

</phone:PhoneApplicationPage>